﻿<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <title>员工管理</title>
    <meta name="viewport" content="width=device-width,initial-scale=1.0,maximum-scale=1.0,user-scalable=no">

    <#include "/common/link.ftl">
    <script>
        function moveSelected(oldRole, newRole) {
            $('.' + newRole).append($('.' + oldRole + ">option:selected"))
        }

        function moveAll(oldRole, newRole) {
            $('.' + newRole).append($('.' + oldRole + ">option"))
        }

        $(function () {
            $(".btn-submit").click(function () {
                $(".selfRoles>option").prop('selected', true);
                $('#editForm').submit()
            })
            let rolediv;
            let checked = $("#admin").prop('checked');
            if (checked) {
                rolediv = $("#roleDiv").remove();
            }
            $("#admin").click(function () {
                checked = $("#admin").prop('checked');
                if (checked) {
                    rolediv = $("#roleDiv").remove();
                } else {
                    $("#adminDiv").after(rolediv)
                    f()
                }
            })
            f()

            function f() {
                var a = [];
                $(".selfRoles>option").each(function (index, ele) {
                    var val = $(ele).val();
                    a.push(val)
                })
                $('.allRoles>option').each(function (index, ele) {
                    let $1 = $(ele);
                    console.log($1);
                    if ($.inArray($1.val(), a) > -1) {
                        $1.remove()
                    }
                })
            }

        })

    </script>
</head>
<body class="hold-transition skin-black sidebar-mini">
<div class="wrapper">
    <#include "/common/navbar.ftl">
    <!--菜单回显-->
    <#assign currentMenu="employee"/>
    <#include "/common/menu.ftl">
    <div class="content-wrapper">
        <section class="content-header">
            <h1>员工编辑</h1>
        </section>
        <section class="content">
            <div class="box">
                <form class="form-horizontal" action="/employee/saveOrUpdate" method="post" id="editForm">
                    <input type="hidden" name="id" value="${employee.id}">
                    <div class="form-group" style="margin-top: 10px;">
                        <label class="col-sm-2 control-label">用户名：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" <#if employee>disabled </#if> name="username"
                                   value="${employee.username}"
                                   placeholder="请输入用户名">
                        </div>
                    </div>
                    <div class="form-group" style="margin-top: 10px;">
                        <label class="col-sm-2 control-label">真实姓名：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" name="name" value="${employee.name}"
                                   placeholder="请输入真实姓名">
                        </div>
                    </div>
                    <#if employee==null>
                        <div class="form-group">
                            <label for="password" class="col-sm-2 control-label">密码：</label>
                            <div class="col-sm-6">
                                <input type="password" class="form-control" id="password" name="password"
                                       value="${employee.password}" placeholder="请输入密码">
                            </div>
                        </div>
                        <div class="form-group">
                            <label for="repassword" class="col-sm-2 control-label">验证密码：</label>
                            <div class="col-sm-6">
                                <input type="password" class="form-control" id="repassword" name="repassword"
                                       placeholder="再输入一遍密码">
                            </div>
                        </div>
                    </#if>
                    <div class="form-group">
                        <label for="email" class="col-sm-2 control-label">电子邮箱：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" name="email" placeholder="请输入邮箱"
                                   value="${employee.email}">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="age" class="col-sm-2 control-label">年龄：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" name="age" placeholder="请输入年龄"
                                   value="${employee.age}">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="dept" class="col-sm-2 control-label">部门：</label>
                        <div class="col-sm-6">
                            <select class="form-control" id="dept" name="dept.id">
                                <#list departments as department>
                                    <option value="${department.id}">${department.name}</option>
                                </#list>
                            </select>
                            <script>
                                $("#dept").val(${employee.dept.id})
                            </script>
                        </div>
                    </div>
                    <div class="form-group" id="adminDiv">
                        <label for="admin" class="col-sm-2 control-label">超级管理员：</label>
                        <div class="col-sm-6" style="margin-left: 15px;">
                            <input type="checkbox"
                                    <#if employee>
                                        ${(employee.admin)?string('checked','')}
                                    </#if>
                                   id="admin" name="admin" class="checkbox">
                        </div>
                    </div>
                    <div class="form-group" id="roleDiv">
                        <label for="role" class="col-sm-2 control-label">分配角色：</label><br/>
                        <div class="row" style="margin-top: 10px">
                            <div class="col-sm-2 col-sm-offset-2">
                                <select multiple class="form-control allRoles" size="15">
                                    <#list roles as role>
                                        <option value="${role.id}">${role.name}</option>
                                    </#list>
                                </select>
                            </div>

                            <div class="col-sm-1" style="margin-top: 60px;" align="center">
                                <div>

                                    <a type="button" class="btn btn-primary  " style="margin-top: 10px" title="右移动"
                                       onclick="moveSelected('allRoles', 'selfRoles')">
                                        <span class="glyphicon glyphicon-menu-right"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="左移动"
                                       onclick="moveSelected('selfRoles', 'allRoles')">
                                        <span class="glyphicon glyphicon-menu-left"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="全右移动"
                                       onclick="moveAll('allRoles', 'selfRoles')">
                                        <span class="glyphicon glyphicon-forward"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="全左移动"
                                       onclick="moveAll('selfRoles', 'allRoles')">
                                        <span class="glyphicon glyphicon-backward"></span>
                                    </a>
                                </div>
                            </div>

                            <div class="col-sm-2">
                                <select multiple class="form-control selfRoles" size="15" name="ids">
                                    <#list employeeRole as employeeRole>
                                        <option value="${employeeRole.id}">
                                            ${employeeRole.name}
                                        </option>
                                    </#list>
                                </select>
                            </div>
                        </div>
                    </div>

                    <div class="form-group">
                        <div class="col-sm-offset-1 col-sm-6">
                            <button type="button" class="btn btn-primary btn-submit">保存</button>
                            <a href="javascript:window.history.back()" class="btn btn-danger">取消</a>
                        </div>
                    </div>

                </form>

            </div>
        </section>
    </div>
    <#include "/common/footer.ftl">
</div>
<script>
    $(document).ready(function () {
        $('#editForm').bootstrapValidator({
            message: 'This value is not valid',
//        live: 'disabled',
            feedbackIcons: {
                valid: 'glyphicon glyphicon-ok',
                invalid: 'glyphicon glyphicon-remove',
                validating: 'glyphicon glyphicon-refresh'
            },
            fields: {
                username: {
                    validators: {
                        notEmpty: {
                            message: '用户名不能为空'
                        },
                        remote: {
                            type: 'POST',
                            url: '/employee/checkUsername',
                            message: '用户名已存在',
                            delay: 1000
                        },
                    }
                },
                age: {
                    validators: {
                        notEmpty: {
                            message: '年龄不能为空'
                        },
                        stringLength: {
                            max:3,
                            min:1,
                            message:"年龄长度错误"
                        }
                    }
                },
                email: {
                    validators: {
                        notEmpty: {
                            message: '邮箱不能为空'
                        },
                        emailAddress: {
                            message: '格式出错'
                        },
                        // remote: {
                        //     type: 'POST',
                        //     url: 'remote.php',
                        //     message: 'The email is not available',
                        //     delay: 2000
                        // }
                    }
                },
                password: {
                    validators: {
                        notEmpty: {
                            message: '密码不可为空'
                        },
                        identical: {
                            field: 'repassword',
                            message: '密码不一致'
                        },
                        different: {
                            field: 'username',
                            message: '密码与用户名不可一致'
                        }
                    }
                },
                repassword: {
                    validators: {
                        notEmpty: {
                            message: '密码不可为空'
                        },
                        identical: {
                            field: 'password',
                            message: '密码不一致'
                        }
                    }
                },
                country: {
                    validators: {
                        notEmpty: {
                            message: 'The country is required and can\'t be empty'
                        }
                    }
                }
            }
        }).on(
            $('.btn-submit').click(function () {
                $.post("/employee/saveOrUpdate",$("#editForm").serialize(),function (data) {
                    if (data.success) {
                        Swal.fire({
                            icon: 'success',
                            title: "操作成功",
                            confirmButtonText: "确认",
                        }).then((result) => {
                            window.location.href = '/employee/list';
                        })
                    } else {
                        Swal.fire(
                            '操作失败!',
                            data.msg,
                            'error'
                        )
                    }
                })
            })
        );
    });
</script>
</body>
</html>
